Dynomotion

Group: DynoMotion Message: 7964 From: deanw1a Date: 7/19/2013
Subject: KMotionCNC Custom Face & ADC readouts
I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).

I am well versed in MFC, C++, etc. (I are a programmer :) Before I jump in, is there any info available that might save me some time?
Best practices on developing a custom face so upgrading to a newer KMotion version is as painless as possible is what I am looking for. Just short, direct tips should be good enough.

Also, I did not see any controls for displaying ADC readings. I plan to have the analog monitor outs on axis servo drives and the spindle VFD read by KAnalog ADCs. My only purpose of reading them is to display them (Torque).
Come to think of it, a display showing encoder derived speed would be nice. For instance, spindle encoder counts displayed as RPM or even some feed rate display (IPM?). I haven't put any thought into that, but it sounds useful.
Has someone else done this? Is there any sample code, helpful instructions?

Have others asked for ADC displays in KMotionCNC?
If I program this feature, would it be possible to have any necessary changes to any base source files included in later releases so I would not need to make changes each time I update?

Thanks,

Dean
Group: DynoMotion Message: 7965 From: tmday7 Date: 7/20/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Hello,
Ive heard of a few people here modifying or even making there own app. I believe Tom has made all the files and source code needed available to do so. I for one would like to be able to do this as Kmotion has a much better trajectory planner then Mach3. But i know nothing of programming language, besides it looks like a lot of work:)
Troy

--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
> I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
>
> I am well versed in MFC, C++, etc. (I are a programmer :) Before I jump in, is there any info available that might save me some time?
> Best practices on developing a custom face so upgrading to a newer KMotion version is as painless as possible is what I am looking for. Just short, direct tips should be good enough.
>
> Also, I did not see any controls for displaying ADC readings. I plan to have the analog monitor outs on axis servo drives and the spindle VFD read by KAnalog ADCs. My only purpose of reading them is to display them (Torque).
> Come to think of it, a display showing encoder derived speed would be nice. For instance, spindle encoder counts displayed as RPM or even some feed rate display (IPM?). I haven't put any thought into that, but it sounds useful.
> Has someone else done this? Is there any sample code, helpful instructions?
>
> Have others asked for ADC displays in KMotionCNC?
> If I program this feature, would it be possible to have any necessary changes to any base source files included in later releases so I would not need to make changes each time I update?
>
> Thanks,
>
> Dean
>
Group: DynoMotion Message: 7967 From: deanw1a Date: 7/20/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Yes, the source is available to do a lot. I do not want to create my own program (too much time involved). I am thinking about extending the KMotionCNC VC program to have some of the features I mentioned. I need to make a "Custom Face" that fits my touch screen monitor and is optimized for touch screen control. Also, I want ADC meters. For instance: Spindle Torque.
I have looked at the code closer and I see that the Custom Face is just a resource provided so existing controls can be repositioned/resized/hidden as desired. I believe I am going to want to add controls.

I will probably approach this by seeing if I can isolate the Custom Face so any Custom Face and associated dialog / controls code can be ported to a new update easily.
If I do this professionally, hopefully, Tom may include the changes in future builds.

At this time, I have no reason to change any other dialogs.

I am not sure when I might start on this project.
If anyone reading this knows of other features that would be nice in the main dialog, let me know and I might be able to include them.
I may take a look at the Mach3 and EMC interfaces to see if I want something KMotionCNC does not have. But, I do not want to make this a full time project :)

Is anyone interested in a special thread for this programming project - for feedback, collaboration, suggestions?

Dean

--- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@...> wrote:
>
> Hello,
> Ive heard of a few people here modifying or even making there own app. I believe Tom has made all the files and source code needed available to do so. I for one would like to be able to do this as Kmotion has a much better trajectory planner then Mach3. But i know nothing of programming language, besides it looks like a lot of work:)
> Troy
>
> --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> >
> > I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
> >
> > I am well versed in MFC, C++, etc. (I are a programmer :) Before I jump in, is there any info available that might save me some time?
> > Best practices on developing a custom face so upgrading to a newer KMotion version is as painless as possible is what I am looking for. Just short, direct tips should be good enough.
> >
> > Also, I did not see any controls for displaying ADC readings. I plan to have the analog monitor outs on axis servo drives and the spindle VFD read by KAnalog ADCs. My only purpose of reading them is to display them (Torque).
> > Come to think of it, a display showing encoder derived speed would be nice. For instance, spindle encoder counts displayed as RPM or even some feed rate display (IPM?). I haven't put any thought into that, but it sounds useful.
> > Has someone else done this? Is there any sample code, helpful instructions?
> >
> > Have others asked for ADC displays in KMotionCNC?
> > If I program this feature, would it be possible to have any necessary changes to any base source files included in later releases so I would not need to make changes each time I update?
> >
> > Thanks,
> >
> > Dean
> >
>
Group: DynoMotion Message: 7968 From: az@aimele.com Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Dean:

I am interested in a custom face also.  I don't know if my requirements line up with your thoughts but I would like to be able to program with a chart rather than the G code. 
My idea is a column for each axis position. Each axis would be a G00 independent rapid motion with the motion parameters set up via the individual axis jog parameters in K motion so speed params are not required on the programming screen.
Some columns could have values that call M codes that use the parameter for use in the M code  possibly a C program call.
If this fits what you're thinking I would be very happy to work with you.

AZ


Group: DynoMotion Message: 7970 From: deanw1a Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
I was only thinking of user interface changes for the main screen for the DROs and jogging controls etc.

It sounds like you are thinking of a custom programming interface. Perhaps an parser that converts your chart into G Code or perhaps an interpreter? That seems way beyond the scope of anything I was considering. I think something like that might be a specific project of its own.
Dean

--- In DynoMotion@yahoogroups.com, "az@..." <az@...> wrote:
>
> Dean:
>
> I am interested in a custom face also. I don't know if my requirements line up with your thoughts but I would like to be able to program with a chart rather than the G code.
> My idea is a column for each axis position. Each axis would be a G00 independent rapid motion with the motion parameters set up via the individual axis jog parameters in K motion so speed params are not required on the programming screen.
> Some columns could have values that call M codes that use the parameter for use in the M code possibly a C program call.
> If this fits what you're thinking I would be very happy to work with you.
>
> AZ
>
>
>
Group: DynoMotion Message: 7971 From: tmday7 Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
A few things i would like to change....
1)Remove extra jog speed buttons and add an input box for jog speed.
2)Make 4th axis screen resizeable.
3)Have Command Position DROs and Actual Encoder Position DROs.

There was more but i forgot them:)

Troy

--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
> I was only thinking of user interface changes for the main screen for the DROs and jogging controls etc.
>
> It sounds like you are thinking of a custom programming interface. Perhaps an parser that converts your chart into G Code or perhaps an interpreter? That seems way beyond the scope of anything I was considering. I think something like that might be a specific project of its own.
> Dean
>
> --- In DynoMotion@yahoogroups.com, "az@" <az@> wrote:
> >
> > Dean:
> >
> > I am interested in a custom face also. I don't know if my requirements line up with your thoughts but I would like to be able to program with a chart rather than the G code.
> > My idea is a column for each axis position. Each axis would be a G00 independent rapid motion with the motion parameters set up via the individual axis jog parameters in K motion so speed params are not required on the programming screen.
> > Some columns could have values that call M codes that use the parameter for use in the M code possibly a C program call.
> > If this fits what you're thinking I would be very happy to work with you.
> >
> > AZ
> >
> >
> >
Group: DynoMotion Message: 7972 From: eric_kato_sanders Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
> I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
>
I'm in the process of creating my own version.
To implement what you descrive, a lot of this work has been done for you already. If you study the source code, you will see that the id for the dialog resource is fed in by the source code. The way to approach this to follow the same scheme, with your custom dialog resource. You will want to subclass the KMotionCNC CDialog derived class with your own, and add your handler for your new controls to your new class. You may need declare some of the original functions as "Virtual" to force the handler to use your implementation instead of the original.
Eric
Group: DynoMotion Message: 7975 From: deanw1a Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
> 1)Remove extra jog speed buttons and add an input box for jog speed.
Are you talking about the Step Size radio buttons from 0.0001 to 10?
I believe that setting is just for the dash (-) step buttons and each of those can be set from the Trajectory Planner page.
Or are you talking about removing the settings on the Trajectory Planner page?
The jog speeds are also set on the Trajectory Planner page. There is a new Slow Jog % setting that sets the first Jog buttons. The speeds from the Trajectory Planner page set the second (outer) Jog Fast button speed. This gives you two jog speeds per axis.
I think it would be best to know how you want to jog. Are you wanting to change the speeds temporarily?
An example of your "work flow" might help. For instance:
"Sometimes I want to jog real slow or real fast. Or, I want to have a way to accelerate and decelerate while jogging so I can traverse quickly to where I want to go and sneak up on the final accurate position."
Knowing what actions you want is sometimes better than a direct feature request. With your goals known, the simplest or most effective change may come to mind.

>>2)Make 4th axis screen resizeable.
I guess you mean you want the Face that is for 4 axis to be resizable.
I would think it would be nice to have all Faces resizable.

>>3)Have Command Position DROs and Actual Encoder Position DROs.
Would the existing DROs be switched to show different values, like the Machine Coord check box does? Or, would they be new displays?
There is a "Display Encoders" checkbox on the Trajectory Planner page.
Is that not what you want?
I am just getting started and I do not know much about the DROs and the data they show (where it comes from, difference between axis position and encoder position, etc.) What is the "Command Position"?

Dean







--- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@...> wrote:
>
> A few things i would like to change....
> 1)Remove extra jog speed buttons and add an input box for jog speed.
> 2)Make 4th axis screen resizeable.
> 3)Have Command Position DROs and Actual Encoder Position DROs.
>
> There was more but i forgot them:)
>
> Troy
>
Group: DynoMotion Message: 7976 From: deanw1a Date: 7/21/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Thanks. I think that is a reasonable approach.
I guess if I inherit from KMotionCNCDlg, I will need to keep all of the original controls and hide any I do not want to use. That should allow new controls to be added.
Studying the KMotionCNCDlg code, it seems that there is a lot of support code written inside of the dialog class. I was thinking of extracting as much code as possible into other classes. That should make any necessary changes to KMotionCNCDlg easier to port to a new version. e.g. If DynoMotion changes support code, it would be a change to a different file. So, doing a diff on KMotionCNCDlg (base class with some changes like virtuals etc) would be easier. Of course, there would still be the new dialog class you are suggesting that would be added to the project.
At the moment, I am extracting the editor logic into a GCodeEditor.h and cpp file (CGCodeEditor). I am not sure how much that will help, but it seems like a start.

Dean



--- In DynoMotion@yahoogroups.com, "eric_kato_sanders" <eric@...> wrote:
>
>
>
> --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> >
> > I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
> >
> I'm in the process of creating my own version.
> To implement what you descrive, a lot of this work has been done for you already. If you study the source code, you will see that the id for the dialog resource is fed in by the source code. The way to approach this to follow the same scheme, with your custom dialog resource. You will want to subclass the KMotionCNC CDialog derived class with your own, and add your handler for your new controls to your new class. You may need declare some of the original functions as "Virtual" to force the handler to use your implementation instead of the original.
> Eric
>
Group: DynoMotion Message: 7977 From: tmday7 Date: 7/22/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Hi Dean,
I was referring to the arrow buttons on the main page. Any axis will jog at the desired set speed until you release arrow button on screen or your keyboard.

I posted a modified main screen on Kmotion CNC. Named KmotionCNCScreeen1.jpg
http://tech.groups.yahoo.com/group/DynoMotion/files/KFLOP%20MillDrill/

Troy

--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
> > 1)Remove extra jog speed buttons and add an input box for jog speed.
> Are you talking about the Step Size radio buttons from 0.0001 to 10?
> I believe that setting is just for the dash (-) step buttons and each of those can be set from the Trajectory Planner page.
> Or are you talking about removing the settings on the Trajectory Planner page?
> The jog speeds are also set on the Trajectory Planner page. There is a new Slow Jog % setting that sets the first Jog buttons. The speeds from the Trajectory Planner page set the second (outer) Jog Fast button speed. This gives you two jog speeds per axis.
> I think it would be best to know how you want to jog. Are you wanting to change the speeds temporarily?
> An example of your "work flow" might help. For instance:
> "Sometimes I want to jog real slow or real fast. Or, I want to have a way to accelerate and decelerate while jogging so I can traverse quickly to where I want to go and sneak up on the final accurate position."
> Knowing what actions you want is sometimes better than a direct feature request. With your goals known, the simplest or most effective change may come to mind.
>
> >>2)Make 4th axis screen resizeable.
> I guess you mean you want the Face that is for 4 axis to be resizable.
> I would think it would be nice to have all Faces resizable.
>
> >>3)Have Command Position DROs and Actual Encoder Position DROs.
> Would the existing DROs be switched to show different values, like the Machine Coord check box does? Or, would they be new displays?
> There is a "Display Encoders" checkbox on the Trajectory Planner page.
> Is that not what you want?
> I am just getting started and I do not know much about the DROs and the data they show (where it comes from, difference between axis position and encoder position, etc.) What is the "Command Position"?
>
> Dean
>
>
>
>
>
>
>
> --- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@> wrote:
> >
> > A few things i would like to change....
> > 1)Remove extra jog speed buttons and add an input box for jog speed.
> > 2)Make 4th axis screen resizeable.
> > 3)Have Command Position DROs and Actual Encoder Position DROs.
> >
> > There was more but i forgot them:)
> >
> > Troy
> >
>
Group: DynoMotion Message: 7978 From: deanw1a Date: 7/22/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
The image helps a lot.
I see - you only want one set of arrow buttons per axis. And, you want them to step or jog according to the radio button "Step, Cont." selection. And, you want to set the jog % on the fly = % of TP page Jog Speed setting (instead of using a Slow Jog% setting).
Look good.

I am thinking I might like sliding/dragging the arrow buttons for jog speed. That would look much like the screen you posted, except the buttons could be pulled/dragged away from center to increase the speed.
I know that may be an issue when using the keyboard?

Is the Command Position the same as what the DROs show by default now and you show the Encoder Pos (Actual Pos) as new, separate displays?

Thanks.


--- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@...> wrote:
>
> Hi Dean,
> I was referring to the arrow buttons on the main page. Any axis will jog at the desired set speed until you release arrow button on screen or your keyboard.
>
> I posted a modified main screen on Kmotion CNC. Named KmotionCNCScreeen1.jpg
> http://tech.groups.yahoo.com/group/DynoMotion/files/KFLOP%20MillDrill/
>
> Troy
>
> --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> >
> > > 1)Remove extra jog speed buttons and add an input box for jog speed.
> > Are you talking about the Step Size radio buttons from 0.0001 to 10?
> > I believe that setting is just for the dash (-) step buttons and each of those can be set from the Trajectory Planner page.
> > Or are you talking about removing the settings on the Trajectory Planner page?
> > The jog speeds are also set on the Trajectory Planner page. There is a new Slow Jog % setting that sets the first Jog buttons. The speeds from the Trajectory Planner page set the second (outer) Jog Fast button speed. This gives you two jog speeds per axis.
> > I think it would be best to know how you want to jog. Are you wanting to change the speeds temporarily?
> > An example of your "work flow" might help. For instance:
> > "Sometimes I want to jog real slow or real fast. Or, I want to have a way to accelerate and decelerate while jogging so I can traverse quickly to where I want to go and sneak up on the final accurate position."
> > Knowing what actions you want is sometimes better than a direct feature request. With your goals known, the simplest or most effective change may come to mind.
> >
> > >>2)Make 4th axis screen resizeable.
> > I guess you mean you want the Face that is for 4 axis to be resizable.
> > I would think it would be nice to have all Faces resizable.
> >
> > >>3)Have Command Position DROs and Actual Encoder Position DROs.
> > Would the existing DROs be switched to show different values, like the Machine Coord check box does? Or, would they be new displays?
> > There is a "Display Encoders" checkbox on the Trajectory Planner page.
> > Is that not what you want?
> > I am just getting started and I do not know much about the DROs and the data they show (where it comes from, difference between axis position and encoder position, etc.) What is the "Command Position"?
> >
> > Dean
> >
> >
> >
> >
> >
> >
> >
> > --- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@> wrote:
> > >
> > > A few things i would like to change....
> > > 1)Remove extra jog speed buttons and add an input box for jog speed.
> > > 2)Make 4th axis screen resizeable.
> > > 3)Have Command Position DROs and Actual Encoder Position DROs.
> > >
> > > There was more but i forgot them:)
> > >
> > > Troy
> > >
> >
>
Group: DynoMotion Message: 7979 From: tmday7 Date: 7/22/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
I think Brad did something similar to the sliders in the WebNC that comes with Kmotion. Which is nice, but as you stated, would be an issue when using the keyboard.

The Command position DROs display the gcode programmed position, like they do know. And the Encoder (Actual) DROs would display separate, to show the position of encoders.

Thanks,
Troy

--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
> The image helps a lot.
> I see - you only want one set of arrow buttons per axis. And, you want them to step or jog according to the radio button "Step, Cont." selection. And, you want to set the jog % on the fly = % of TP page Jog Speed setting (instead of using a Slow Jog% setting).
> Look good.
>
> I am thinking I might like sliding/dragging the arrow buttons for jog speed. That would look much like the screen you posted, except the buttons could be pulled/dragged away from center to increase the speed.
> I know that may be an issue when using the keyboard?
>
> Is the Command Position the same as what the DROs show by default now and you show the Encoder Pos (Actual Pos) as new, separate displays?
>
> Thanks.
>
>
> --- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@> wrote:
> >
> > Hi Dean,
> > I was referring to the arrow buttons on the main page. Any axis will jog at the desired set speed until you release arrow button on screen or your keyboard.
> >
> > I posted a modified main screen on Kmotion CNC. Named KmotionCNCScreeen1.jpg
> > http://tech.groups.yahoo.com/group/DynoMotion/files/KFLOP%20MillDrill/
> >
> > Troy
> >
> > --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> > >
> > > > 1)Remove extra jog speed buttons and add an input box for jog speed.
> > > Are you talking about the Step Size radio buttons from 0.0001 to 10?
> > > I believe that setting is just for the dash (-) step buttons and each of those can be set from the Trajectory Planner page.
> > > Or are you talking about removing the settings on the Trajectory Planner page?
> > > The jog speeds are also set on the Trajectory Planner page. There is a new Slow Jog % setting that sets the first Jog buttons. The speeds from the Trajectory Planner page set the second (outer) Jog Fast button speed. This gives you two jog speeds per axis.
> > > I think it would be best to know how you want to jog. Are you wanting to change the speeds temporarily?
> > > An example of your "work flow" might help. For instance:
> > > "Sometimes I want to jog real slow or real fast. Or, I want to have a way to accelerate and decelerate while jogging so I can traverse quickly to where I want to go and sneak up on the final accurate position."
> > > Knowing what actions you want is sometimes better than a direct feature request. With your goals known, the simplest or most effective change may come to mind.
> > >
> > > >>2)Make 4th axis screen resizeable.
> > > I guess you mean you want the Face that is for 4 axis to be resizable.
> > > I would think it would be nice to have all Faces resizable.
> > >
> > > >>3)Have Command Position DROs and Actual Encoder Position DROs.
> > > Would the existing DROs be switched to show different values, like the Machine Coord check box does? Or, would they be new displays?
> > > There is a "Display Encoders" checkbox on the Trajectory Planner page.
> > > Is that not what you want?
> > > I am just getting started and I do not know much about the DROs and the data they show (where it comes from, difference between axis position and encoder position, etc.) What is the "Command Position"?
> > >
> > > Dean
> > >
> > >
> > >
> > >
> > >
> > >
> > >
> > > --- In DynoMotion@yahoogroups.com, "tmday7" <tmday88@> wrote:
> > > >
> > > > A few things i would like to change....
> > > > 1)Remove extra jog speed buttons and add an input box for jog speed.
> > > > 2)Make 4th axis screen resizeable.
> > > > 3)Have Command Position DROs and Actual Encoder Position DROs.
> > > >
> > > > There was more but i forgot them:)
> > > >
> > > > Troy
> > > >
> > >
> >
>
Group: DynoMotion Message: 8059 From: deanw1a Date: 8/2/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
Warning... programmer geek speak ahead...

I would like to know what the programmers who have (or want to have) their own controls think about the following:

I wanted to isolate the custom code and resources. So, I added a directory = KMotionCNC\Custom Dialogs and a res dir under it to hold bitmaps etc.

I added a CCustomDlg dialog class (inherits from KMotionCNCDlg) and a new CustomDlg.rc file in this directory. I also placed new files with control classes there.

I increased the NEXT ID values in CustomDlg.rc to keep KMotionCNC.rc future additions from using the same IDs.

I took the resource.h IDs and moved them to ResourceShared.h and set both rc files Resource Includes... / Read only includes to include it.
That allows both rc files to see the IDs and keeps either from changing their values.

Also, I put a copy of the IDD_KMOTIONCNC_7_CUSTOM resource in CCustomDlg.rc as IDD_KMOTIONCNC_7_CUSTOM_OLD. It can be used to see a diff - to find what additional controls etc. have been added to a new release.

That does not do a lot. But, I like it. Do you?

I changed CFrame.GCodeDlg to a pointer and replaced all GCodeDlg. references in other files with GCodeDlg->
Also, there were two "&" references in the callbacks in KMotionCNCDlg.cpp that need to be changed.

I added a new file GCodeDlgFactory with a static KMotionCNCDlg *CreateDlg() call that returns a KMotionCNCDlg pointer it creates. I call this from CFrame. CreateDlg just returns a new CCustomDlg(). The release code would return a new CKMotionCNCDlg(). You would just change it to create your derived class. GCodeDlgFactory.h & cpp are in the Custom Dialogs directory so they would be copied to a new release.

I also needed to set a KMotionCNCDlg method to virtual, add a new method or two and change the private: section to protected:

That is a short summary.

If these changes are included in a new release:

Users with custom code would need to change their GCodeDlg. references to GCodeDlg->
Other than that, they should be able to continue whatever they were doing. Or, they could place their code into the Custom Dialogs directory and their resources in CCustomDlg.rc if they want to.

This doesn't really do a lot, but it provides some structure / separation without having to repeat it when porting to a new release.
I think it eases porting a little bit.

I also plan on adding some samples, utilities and controls.

There are more details, but I am trying to keep this fairly short.

Is anyone interested in seeing these changes in a future release?

Would these changes make anyone's job of porting their custom code to a new release difficult? Easier?

Does anyone have any more ideas on how to make adding new controls etc. to KMotionCNC and porting the changes to a new release easier?

Thanks.


--- In DynoMotion@yahoogroups.com, "eric_kato_sanders" <eric@...> wrote:
>
>
>
> --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> >
> > I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
> >
> I'm in the process of creating my own version.
> To implement what you descrive, a lot of this work has been done for you already. If you study the source code, you will see that the id for the dialog resource is fed in by the source code. The way to approach this to follow the same scheme, with your custom dialog resource. You will want to subclass the KMotionCNC CDialog derived class with your own, and add your handler for your new controls to your new class. You may need declare some of the original functions as "Virtual" to force the handler to use your implementation instead of the original.
> Eric
>
Group: DynoMotion Message: 8070 From: eric_kato_sanders Date: 8/5/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts
One thing I would do is instead of using the dlg class pointer directly, make it a frame function call to return the dlg pointer. The Frame class calls a virtual dlg class function that returns a "this;". That way you always get the inherited pointer.
The problem would be where the pointer is created, then set, and then used. The pointer type would still be set to the original dlg class. You could use a macro to keep the code looking clean. I think the compiler optimization would automatically create a single pointer instance and use that instead of separate Frame.GetDlgPtr() calls anyway.
Eric

--- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@...> wrote:
>
>
>
>
> Warning... programmer geek speak ahead...
>
> I would like to know what the programmers who have (or want to have) their own controls think about the following:
>
> I wanted to isolate the custom code and resources. So, I added a directory = KMotionCNC\Custom Dialogs and a res dir under it to hold bitmaps etc.
>
> I added a CCustomDlg dialog class (inherits from KMotionCNCDlg) and a new CustomDlg.rc file in this directory. I also placed new files with control classes there.
>
> I increased the NEXT ID values in CustomDlg.rc to keep KMotionCNC.rc future additions from using the same IDs.
>
> I took the resource.h IDs and moved them to ResourceShared.h and set both rc files Resource Includes... / Read only includes to include it.
> That allows both rc files to see the IDs and keeps either from changing their values.
>
> Also, I put a copy of the IDD_KMOTIONCNC_7_CUSTOM resource in CCustomDlg.rc as IDD_KMOTIONCNC_7_CUSTOM_OLD. It can be used to see a diff - to find what additional controls etc. have been added to a new release.
>
> That does not do a lot. But, I like it. Do you?
>
> I changed CFrame.GCodeDlg to a pointer and replaced all GCodeDlg. references in other files with GCodeDlg->
> Also, there were two "&" references in the callbacks in KMotionCNCDlg.cpp that need to be changed.
>
> I added a new file GCodeDlgFactory with a static KMotionCNCDlg *CreateDlg() call that returns a KMotionCNCDlg pointer it creates. I call this from CFrame. CreateDlg just returns a new CCustomDlg(). The release code would return a new CKMotionCNCDlg(). You would just change it to create your derived class. GCodeDlgFactory.h & cpp are in the Custom Dialogs directory so they would be copied to a new release.
>
> I also needed to set a KMotionCNCDlg method to virtual, add a new method or two and change the private: section to protected:
>
> That is a short summary.
>
> If these changes are included in a new release:
>
> Users with custom code would need to change their GCodeDlg. references to GCodeDlg->
> Other than that, they should be able to continue whatever they were doing. Or, they could place their code into the Custom Dialogs directory and their resources in CCustomDlg.rc if they want to.
>
> This doesn't really do a lot, but it provides some structure / separation without having to repeat it when porting to a new release.
> I think it eases porting a little bit.
>
> I also plan on adding some samples, utilities and controls.
>
> There are more details, but I am trying to keep this fairly short.
>
> Is anyone interested in seeing these changes in a future release?
>
> Would these changes make anyone's job of porting their custom code to a new release difficult? Easier?
>
> Does anyone have any more ideas on how to make adding new controls etc. to KMotionCNC and porting the changes to a new release easier?
>
> Thanks.
>
>
> --- In DynoMotion@yahoogroups.com, "eric_kato_sanders" <eric@> wrote:
> >
> >
> >
> > --- In DynoMotion@yahoogroups.com, "deanw1a" <deanwyant@> wrote:
> > >
> > > I can't seem to find any discussion or docs with tips on developing a custom face for KMotionCNC. (Using the Custom selection for "Face" or some other way).
> > >
> > I'm in the process of creating my own version.
> > To implement what you descrive, a lot of this work has been done for you already. If you study the source code, you will see that the id for the dialog resource is fed in by the source code. The way to approach this to follow the same scheme, with your custom dialog resource. You will want to subclass the KMotionCNC CDialog derived class with your own, and add your handler for your new controls to your new class. You may need declare some of the original functions as "Virtual" to force the handler to use your implementation instead of the original.
> > Eric
> >
>
Group: DynoMotion Message: 8299 From: deanw1a Date: 9/9/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts

Sorry for the late reply...

I do not understand what you mean.

What I did was move the creation of the dialog into its own file so future file changes by DynoMotion to the frame etc. would not affect it. This was a change to Frame and an added file. It isn't a "true" factory.

How can the Frame call a virtual dialog function that returns a "this" when it needs a pointer to the dialog to call it? What files would change when someone wants to have their dialog class used?

 
Some changes to access methods etc. would be nice, but I am trying to minimze changes to existing code. So far, I just require a few changes to the KMotionCNCDlg.h and Frame.. and project changes.
 
Actually, the changes to make updating to a newer version when using a custom dialog easier have been done for a while. I am working on a runtime layout manager that should allow users to design their custom dialogs without code changes. You dialog has new controls so it might not be able to be emulated.  
I noticed that on your custom dialog you have different DRO controls and buttons.
I might be able to use some of the code/controls you have if they are free licensed. Also, perhaps the probe functions can be generic for other usesrs to benifit from? If you can share your code, I would like to get a copy.
I want to make see if the layout manager can allow adding the type of controls and functionality you are using.
 
Thanks.
Dean
--- In DynoMotion@yahoogroups.com, <dynomotion@yahoogroups.com> wrote:

One thing I would do is instead of using the dlg class pointer directly, make it a frame function call to return the dlg pointer. The Frame class calls a virtual dlg class function that returns a "this;". That way you always get the inherited pointer.
The problem would be where the pointer is created, then set, and then used. The pointer type would still be set to the original dlg class. You could use a macro to keep the code looking clean. I think the compiler optimization would automatically create a single pointer instance and use that instead of separate Frame.GetDlgPtr() calls anyway.
Eric
Group: DynoMotion Message: 8310 From: eric_kato_sanders Date: 9/10/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts

 Hi Dean,

In the end, what I ended up doing was creating my own dialog class inherited from the original class.  The original class needed several functions redefined as virtual so that mine could handle the calls.  The custom controls are licensed from an old National Instruments version of Measurement and Automation.  There are many good looking custom controls out there that could be used instead.  The buttons around the DRO's are stock buttons from the KMotion code.  I just created new bitmaps to load into them to make them look a bit better.  The probing can be fully customized by your implementation of a .c file.  I pass in several parameters, the first of which is a constant that tells the probing routine what kind of probing should be performed, (inside hole, outside boss, left edge, etc..).  The rest are some of the parameter in the window such as Edge Length, and so forth.

I'm not sure how a layout manager would work.  You might be able to create new screens, but some of your code won't be called by the base class because they are not marked as virtual.  It would be nice if Tom made them virtual in his code.  There would be no repercussions on his side in doing so..

I do plan on posting all my code in the near future.  I still physically don't have the KFlop hooked up yet to my mill for testing.  I just don't seem to have the time with my daughter's soccer season in full swing...

Eric



--- In dynomotion@yahoogroups.com, <deanwyant@...> wrote:

Sorry for the late reply...

I do not understand what you mean.

What I did was move the creation of the dialog into its own file so future file changes by DynoMotion to the frame etc. would not affect it. This was a change to Frame and an added file. It isn't a "true" factory.

How can the Frame call a virtual dialog function that returns a "this" when it needs a pointer to the dialog to call it? What files would change when someone wants to have their dialog class used?

 
Some changes to access methods etc. would be nice, but I am trying to minimze changes to existing code. So far, I just require a few changes to the KMotionCNCDlg.h and Frame.. and project changes.
 
Actually, the changes to make updating to a newer version when using a custom dialog easier have been done for a while. I am working on a runtime layout manager that should allow users to design their custom dialogs without code changes. You dialog has new controls so it might not be able to be emulated.  
I noticed that on your custom dialog you have different DRO controls and buttons.
I might be able to use some of the code/controls you have if they are free licensed. Also, perhaps the probe functions can be generic for other usesrs to benifit from? If you can share your code, I would like to get a copy.
I want to make see if the layout manager can allow adding the type of controls and functionality you are using.
 
Thanks.
Dean
--- In DynoMotion@yahoogroups.com, <dynomotion@yahoogroups.com> wrote:

One thing I would do is instead of using the dlg class pointer directly, make it a frame function call to return the dlg pointer. The Frame class calls a virtual dlg class function that returns a "this;". That way you always get the inherited pointer.
The problem would be where the pointer is created, then set, and then used. The pointer type would still be set to the original dlg class. You could use a macro to keep the code looking clean. I think the compiler optimization would automatically create a single pointer instance and use that instead of separate Frame.GetDlgPtr() calls anyway.
Eric
Group: DynoMotion Message: 8312 From: deanw1a Date: 9/11/2013
Subject: Re: KMotionCNC Custom Face & ADC readouts

OK, I was thinking that the controls might be free.

 

The dialog is a : KMotionCNCDlg.

I am counting on the KmotionCNCDlg code being changed to set approriate methods as virtual, etc. A few small changes that should not affect user code.

I would like to know which changes you needed so I can include them when I submit the changes to Tom.

I believe I also needed to add a call and change something to protected from private.

 

It sounds like the probing can be done with user buttons set to run a KFlop thread and pass parameters to it.

If so, then that is covered in the layout manager... the buttons can be added on the fly.... and even put on their own tab. Of course, the .c code is not part of the manager. And, it will take hours to configure everything and get the display the way you want it. :)
 
Are the images for probing free?  It would be nice to include them and/or others.
 
For buttons, I looked and could not find any button controls that had the features I wanted. So, I wrote one.
It does not have a hover state/effect - no time for that now.
 
I was looking for a slider to control DACs. I have looked at bunches of them on CodeProject etc. but I have not
found one I like. I think I will just use the one that is already there. Perhaps later I will add a bitmapped slider.
 
I do not know about DRO's... any suggestions?
 
I should have this ready for beta in a month or so.
 
Dean

--- In DynoMotion@yahoogroups.com, <dynomotion@yahoogroups.com> wrote:

 Hi Dean,

In the end, what I ended up doing was creating my own dialog class inherited from the original class.  The original class needed several functions redefined as virtual so that mine could handle the calls.  The custom controls are licensed from an old National Instruments version of Measurement and Automation.  There are many good looking custom controls out there that could be used instead.  The buttons around the DRO's are stock buttons from the KMotion code.  I just created new bitmaps to load into them to make them look a bit better.  The probing can be fully customized by your implementation of a .c file.  I pass in several parameters, the first of which is a constant that tells the probing routine what kind of probing should be performed, (inside hole, outside boss, left edge, etc..).  The rest are some of the parameter in the window such as Edge Length, and so forth.

I'm not sure how a layout manager would work.  You might be able to create new screens, but some of your code won't be called by the base class because they are not marked as virtual.  It would be nice if Tom made them virtual in his code.  There would be no repercussions on his side in doing so..

I do plan on posting all my code in the near future.  I still physically don't have the KFlop hooked up yet to my mill for testing.  I just don't seem to have the time with my daughter's soccer season in full swing...

Eric



--- In dynomotion@yahoogroups.com, <deanwyant@...> wrote:

Sorry for the late reply...

I do not understand what you mean.

What I did was move the creation of the dialog into its own file so future file changes by DynoMotion to the frame etc. would not affect it. This was a change to Frame and an added file. It isn't a "true" factory.

How can the Frame call a virtual dialog function that returns a "this" when it needs a pointer to the dialog to call it? What files would change when someone wants to have their dialog class used?

 
Some changes to access methods etc. would be nice, but I am trying to minimze changes to existing code. So far, I just require a few changes to the KMotionCNCDlg.h and Frame.. and project changes.
 
Actually, the changes to make updating to a newer version when using a custom dialog easier have been done for a while. I am working on a runtime layout manager that should allow users to design their custom dialogs without code changes. You dialog has new controls so it might not be able to be emulated.  
I noticed that on your custom dialog you have different DRO controls and buttons.
I might be able to use some of the code/controls you have if they are free licensed. Also, perhaps the probe functions can be generic for other usesrs to benifit from? If you can share your code, I would like to get a copy.
I want to make see if the layout manager can allow adding the type of controls and functionality you are using.
 
Thanks.
Dean
--- In DynoMotion@yahoogroups.com, <dynomotion@yahoogroups.com> wrote:

One thing I would do is instead of using the dlg class pointer directly, make it a frame function call to return the dlg pointer. The Frame class calls a virtual dlg class function that returns a "this;". That way you always get the inherited pointer.
The problem would be where the pointer is created, then set, and then used. The pointer type would still be set to the original dlg class. You could use a macro to keep the code looking clean. I think the compiler optimization would automatically create a single pointer instance and use that instead of separate Frame.GetDlgPtr() calls anyway.
Eric